البرمجة

تنسيق النصوص في بايثون 3

كيفية تنسيق النصوص في بايثون 3: دليل شامل وموسع

يُعد تنسيق النصوص (Text Formatting) من المهارات الأساسية في لغة البرمجة بايثون 3، والتي لا غنى عنها لأي مبرمج يسعى لبناء برامج تفاعلية، واضحة وسهلة القراءة. تُستخدم تقنيات تنسيق النصوص في طباعة النتائج، توليد تقارير، التعامل مع البيانات النصية، وتخصيص المخرجات بحسب السياق أو المتطلبات. تتعدد الأساليب المتاحة في بايثون لتنسيق النصوص، بدءًا من التنسيق التقليدي باستخدام عامل النسبة المئوية %، مرورًا بدالة .format()، ووصولًا إلى أسلوب التنسيق باستخدام f-Strings الذي تم تقديمه في إصدار Python 3.6.

تتناول هذه المقالة الموسعة جميع الجوانب المتعلقة بتنسيق النصوص في بايثون 3، مع عرض تفصيلي للأمثلة العملية، والخصائص التقنية لكل طريقة، بالإضافة إلى جدول شامل يقارن بين هذه الطرق. يشمل المقال أيضًا بعض التحديات الشائعة وكيفية التعامل معها بكفاءة.


أولًا: التنسيق باستخدام عامل النسبة المئوية %

هذه الطريقة تُعد من الأساليب القديمة في بايثون، ولكنها لا تزال مستخدمة في الكثير من الشيفرات، خصوصًا التي تم تطويرها في الإصدارات الأقدم من Python 3.

الصيغة الأساسية:

python
"النص %s يحتوي على رقم %d" % ("هذا", 100)

رموز التنسيق المستخدمة:

الرمز المعنى
%s سلسلة نصية
%d عدد صحيح
%f عدد عشري
%.2f عدد عشري بدقة منزلتين
%x عدد بالنظام الست عشري

مثال عملي:

python
name = "علي" age = 30 print("اسمي %s وعمري %d سنة." % (name, age))

المميزات:

  • بسيط وسريع الاستخدام.

  • مفيد في الشيفرات القديمة.

العيوب:

  • لا يدعم الترتيب الديناميكي للوسائط.

  • يفتقر إلى القابلية للتوسّع في التطبيقات المعقدة.


ثانيًا: التنسيق باستخدام .format()

تم تقديم هذا الأسلوب في بايثون 2.6 وتحسّن بشكل كبير في Python 3. يعتمد على استخدام أقواس {} داخل النص واستدعاء دالة .format() لتمرير القيم.

الصيغة الأساسية:

python
"النص {} يحتوي على رقم {}".format("هذا", 100)

الأمثلة:

الترتيب حسب الموقع:

python
name = "أحمد" age = 25 print("اسمي {} وعمري {} سنة".format(name, age))

الترتيب حسب الفهرس:

python
print("العدد الأول {0} والعدد الثاني {1}".format(10, 20))

الترتيب حسب الاسم:

python
print("اسمي {name} وعمري {age}".format(name="منى", age=22))

تنسيق الأرقام:

python
price = 1234.5678 print("السعر: {:.2f} ريال".format(price)) # السعر: 1234.57 ريال

محاذاة وتنسيق:

الرمز المعنى
:< محاذاة لليسار داخل حقل معين
:> محاذاة لليمين داخل حقل معين
:^ توسيط داخل حقل معين
:0>5 ملء بالأصفار حتى الطول 5 مع المحاذاة يمين
python
print("{:>10}".format("مرحبا")) # مرحبا print("{:<10}".format("مرحبا")) # مرحبا print("{:^10}".format("مرحبا")) # مرحبا

المميزات:

  • مرونة عالية.

  • يدعم تنسيق متقدم للنصوص والأرقام.

  • يتيح استخدام أسماء المتغيرات مباشرة.

العيوب:

  • أكثر تعقيدًا من الطريقة القديمة.


ثالثًا: التنسيق باستخدام f-Strings (ابتداءً من Python 3.6)

يُعد التنسيق باستخدام f-Strings أو ما يُعرف بـ "Formatted String Literals" الطريقة الأحدث والأكثر فعالية لتنسيق النصوص في بايثون. وهي تعتمد على كتابة الحرف f قبل السلسلة النصية، وتضمين المتغيرات مباشرة داخل الأقواس المعقوفة {}.

الصيغة الأساسية:

python
f"النص {variable} يحتوي على رقم {number}"

مثال عملي:

python
name = "خالد" age = 40 print(f"اسمي {name} وعمري {age} سنة.")

استخدام التعابير داخل f-Strings:

python
print(f"العدد المضاعف هو: {age * 2}")

تنسيق الأرقام داخل f-Strings:

python
price = 1234.5678 print(f"السعر: {price:.2f} ريال") # السعر: 1234.57 ريال

محاذاة وتنسيق داخل f-Strings:

python
text = "Python" print(f"{text:>10}") # محاذاة لليمين print(f"{text:<10}") # محاذاة لليسار print(f"{text:^10}") # توسيط

المميزات:

  • طريقة واضحة، مختصرة، وقوية.

  • تدعم التعابير مباشرة.

  • أكثر كفاءة في الأداء من .format().

العيوب:

  • غير متاحة في إصدارات Python الأقدم من 3.6.


جدول مقارنة بين طرق التنسيق الثلاثة

الخاصية التنسيق بـ % .format() f-Strings
المتوفرة في الإصدارات Python 2 & 3 Python 2.6+ Python 3.6+
القابلية للتوسّع محدودة عالية عالية جدًا
الأداء متوسط أبطأ الأفضل
قابلية قراءة الشيفرة متوسطة جيدة ممتازة
دعم التعبيرات داخل النص لا نعم نعم
التوصية العامة لا يُفضّل استخدامها مناسبة للتنسيقات المركبة الأفضل في معظم الحالات

تنسيق النصوص متعددة الأسطر

في بعض الأحيان، تحتاج إلى تنسيق فقرات أو نصوص طويلة تمتد على عدة أسطر، ويمكن استخدام الطرق السابقة ضمن سلاسل نصية متعددة الأسطر:

python
name = "سارة" age = 33 job = "مهندسة برمجيات" message = f""" الاسم: {name} العمر: {age} الوظيفة: {job} """ print(message)

التنسيق باستخدام المكتبة القياسية string

توفر مكتبة string في بايثون بعض الأدوات المتقدمة لتنسيق النصوص. ومن أشهرها:

python
import string template = string.Template("مرحبًا يا $name! لديك $count رسالة.") output = template.substitute(name="ليلى", count=5) print(output)

المميزات:

  • طريقة آمنة للتنسيق مع مدخلات المستخدم.

  • مفيدة في التعامل مع ملفات التكوين والنماذج الجاهزة.


التعامل مع الأخطاء أثناء التنسيق

عند تنسيق النصوص، يمكن أن تواجه أخطاء مثل:

  • عدم تطابق عدد الحقول مع عدد القيم.

  • استخدام متغير غير معرف.

  • إدخال نوع غير متوافق مع الرمز (مثل تمرير سلسلة نصية إلى %d).

أمثلة للأخطاء الشائعة:

python
# خطأ: عدد القيم أقل من عدد الحقول print("اسمي {} وعمري {} سنة".format("علي"))
python
# خطأ: اسم المتغير غير معرف print(f"العمر: {user_age}")

لحل هذه المشكلات، يجب التأكد من:

  • مطابقة عدد الحقول مع عدد القيم.

  • التحقق من تعريف جميع المتغيرات.

  • اختيار الرموز المناسبة لنوع البيانات.


ممارسات فعّالة لتنسيق النصوص

  • استخدام f-Strings كلما كان ذلك ممكنًا لسهولة القراءة وكفاءة الأداء.

  • اعتماد .format() في الحالات التي تتطلب مرونة في ترتيب القيم أو عند استخدام قوالب نصوص ديناميكية.

  • تجنب استخدام % إلا في الشيفرات القديمة أو لأغراض تعليمية.

  • التأكد من عدم الكشف عن بيانات حساسة أثناء التنسيق، خصوصًا عند التعامل مع مدخلات المستخدم.

  • عند التعامل مع ملفات ضخمة أو مخرجات تقارير، يمكن بناء السلاسل النصية تدريجيًا باستخدام الانضمام join() بدلاً من التنسيقات الثقيلة.


الخلاصة التقنية

تنسيق النصوص في بايثون 3 يُعد من الجوانب المحورية في تطوير البرمجيات الحديثة. يتيح تنسيق النصوص إنتاج مخرجات دقيقة، منسقة وواضحة للمستخدم النهائي، سواء في تطبيقات الطرفية أو الواجهات الرسومية أو تقارير البيانات. ومع التطور السريع في لغة بايثون، يُعتبر استخدام f-Strings هو الخيار الأمثل لما يوفره من سهولة وكفاءة، في حين تظل الطرق الأخرى صالحة بحسب الحاجة وسياق الاستخدام.


المصادر

  1. Python Documentation – Text Sequence Type — str: https://docs.python.org/3/library/stdtypes.html#text-sequence-type-str

  2. PEP 498 – Literal String Interpolation (f-strings): https://peps.python.org/pep-0498/